var thisPageUrl = location.href.split('#')[0];
// alert(thisPageUrl);
var _title = '外教君-TPO';
var _desc =  '我在外教君TPO已练习5天，掌握239个词汇！ 离满分更近一步！';
var _link = 'http://tpo.waijiaojun.com/tpo/share/';
var _imgUrl = 'http://tpo.waijiaojun.com/tpo/img/Group@2x.png';
$.ajax({ url: "http://tpo.waijiaojun.com/tpo/jsapi/ajax/sign",
    type: "POST",
    data:{url:""+thisPageUrl},
    dataType: "json",
    //sync: true,
    cache: false,//解决三星手机，缓存后不提交请求
    success: function(data){
        console.log(data);
        // alert(JSON.stringify(data));
        if(data.success){
            configWeiXin(data.appId,data.timestamp,data.nonceStr,data.signature);
            _link += data.openid;
            _desc = _desc.replace("5",data.studyDays).replace("239",data.quantityOfVocabulary);
            console.log(_desc);
            //regiestWxJsApi();
        }else{
            console.log("配置weixin jsapi失败");
        }

    },
    error: function(XMLHttpRequest, textStatus, errorThrown){
        console.log(XMLHttpRequest.responseText);
    }
});

/*
 * 注意：
 * 1. 所有的JS接口只能在公众号绑定的域名下调用，公众号开发者需要先登录微信公众平台进入“公众号设置”的“功能设置”里填写“JS接口安全域名”。
 * 2. 如果发现在 Android 不能分享自定义内容，请到官网下载最新的包覆盖安装，Android 自定义分享接口需升级至 6.0.2.58 版本及以上。
 * 3. 常见问题及完整 JS-SDK 文档地址：http://mp.weixin.qq.com/wiki/7/aaa137b55fb2e0456bf8dd9148dd613f.html
 *
 * 开发中遇到问题详见文档“附录5-常见错误及解决办法”解决，如仍未能解决可通过以下渠道反馈：
 * 邮箱地址：weixin-open@qq.com
 * 邮件主题：【微信JS-SDK反馈】具体问题
 * 邮件内容说明：用简明的语言描述问题所在，并交代清楚遇到该问题的场景，可附上截屏图片，微信团队会尽快处理你的反馈。
 */
function configWeiXin(appId, timestamp, nonceStr, signature){
    wx.config({
        debug: false,// 开启调试模式,调用的所有api的返回值会在客户端alert出来，若要查看传入的参数，可以在pc端打开，参数信息会通过log打出，仅在pc端时才会打印。
        appId: appId,
        timestamp: timestamp,
        nonceStr: nonceStr,
        signature: signature,
        jsApiList: [
            'checkJsApi',
            'onMenuShareTimeline',
            'onMenuShareAppMessage',
            'onMenuShareQQ',
            'onMenuShareWeibo',
            'hideMenuItems',
            'showMenuItems',
            'hideAllNonBaseMenuItem',
            'showAllNonBaseMenuItem',
            'translateVoice',
            'startRecord',
            'stopRecord',
            'onRecordEnd',
            'playVoice',
            'pauseVoice',
            'stopVoice',
            'uploadVoice',
            'downloadVoice',
            'chooseImage',
            'previewImage',
            'uploadImage',
            'downloadImage',
            'getNetworkType',
            'openLocation',
            'getLocation',
            'hideOptionMenu',
            'showOptionMenu',
            'closeWindow',
            'scanQRCode',
            'chooseWXPay',
            'openProductSpecificView',
            'addCard',
            'chooseCard',
            'openCard'
        ]
    });
}

//
function regiestWxJsApi(){
}

// config信息验证后会执行ready方法，所有接口调用都必须在config接口获得结果之后，config是一个客户端的异步操作，所以如果需要在页面加载时就调用相关接口
//，则须把相关接口放在ready函数中调用来确保正确执行。对于用户触发时才调用的接口，则可以直接调用，不需要放在ready函数中。
wx.ready(function(){
    //wx.hideOptionMenu();
    //分享到朋友圈
    wx.onMenuShareTimeline({
        title: _desc, // 分享标题
        link: _link, // 分享链接，该链接域名或路径必须与当前页面对应的公众号JS安全域名一致
        imgUrl: _imgUrl, // 分享图标
        success: function () {
            // 用户确认分享后执行的回调函数
            //alert('感谢分享!!');
        },
        cancel: function () {
            // 用户取消分享后执行的回调函数
            //alert('取消分享!!');
        }
    });
    //分享给朋友
    wx.onMenuShareAppMessage({
        title: _title, // 分享标题
        desc: _desc, // 分享描述
        link: _link, // 分享链接，该链接域名或路径必须与当前页面对应的公众号JS安全域名一致
        imgUrl: _imgUrl, // 分享图标
        type: '', // 分享类型,music、video或link，不填默认为link
        dataUrl: '', // 如果type是music或video，则要提供数据链接，默认为空
        success: function () {
            // 用户确认分享后执行的回调函数
            //alert('感谢分享!');
        },
        cancel: function () {
            // 用户取消分享后执行的回调函数
            //alert('取消分享!');
        }
    });

    //分享到QQ
    wx.onMenuShareQQ({
        title: _title, // 分享标题
        desc: _desc, // 分享描述
        link: _link, // 分享链接
        imgUrl: _imgUrl, // 分享图标
        success: function () {
            // 用户确认分享后执行的回调函数
        },
        cancel: function () {
            // 用户取消分享后执行的回调函数
        }
    });

    //分享到腾讯微博
    wx.onMenuShareWeibo({
        title: _title, // 分享标题
        desc: _desc, // 分享描述
        link: _link, // 分享链接
        imgUrl: _imgUrl, // 分享图标
        success: function () {
            // 用户确认分享后执行的回调函数
        },
        cancel: function () {
            // 用户取消分享后执行的回调函数
        }
    });

    // 分享到QQ空间
    wx.onMenuShareQZone({
        title: _title, // 分享标题
        desc: _desc, // 分享描述
        link:_link, // 分享链接
        imgUrl: _imgUrl, // 分享图标
        success: function () {
            // 用户确认分享后执行的回调函数
        },
        cancel: function () {
            // 用户取消分享后执行的回调函数
        }
    });

});

wx.error(function(res){
    alert("config信息验证失败");
    // config信息验证失败会执行error函数，如签名过期导致验证失败，具体错误信息可以打开config的debug模式查看，也可以在返回的res参数中查看，对于SPA可以在这里更新签名。

});

// wx.checkJsApi({
//     jsApiList: ['chooseWXPay','onMenuShareTimeline','onMenuShareAppMessage'], // 需要检测的JS接口列表，所有JS接口列表见附录2,
//     success: function(res) {
//         // 以键值对的形式返回，可用的api值true，不可用为false
//         // 如：{"checkResult":{"chooseImage":true},"errMsg":"checkJsApi:ok"}
//          alert("checkJsApi"+JSON.stringify(res));
//     },
//     error:function(res){
//         alert("checkJsApi"+JSON.stringify(res));
//     }
// });

var url = location.search;
var theRequest = new Object();
if (url.indexOf("?") != -1) {
    var str = url.substr(1);
    var strs = str.split("&");
    for (var i = 0; i < strs.length; i++) {
        theRequest[strs[i].split("=")[0]] = ( strs[i].split("=")[1] );
    }
    console.log(theRequest);
}
